

#### **Generic Timer Module (GTM)**

Please note, that the debug mechanism should not be used by the application, when a HW-Debugger is used to trace the ARU communication. In that case, the debug registers are used by the HW-Debugger to specify the ARU streams that should be traced.

## 28.5.4 ARU dynamic routing

A dynamic routing feature of the ARU is implemented and can be configured using the additional AEI registers:,

- ARU\_CTRL
- ARU\_[x]\_DYN\_CTRL
- ARU\_[x]\_DYN\_RDADDR
- ARU\_[x]\_DYN\_ROUTE\_LOW
- ARU\_[x]\_DYN\_ROUTE\_HIGH
- ARU\_[x]\_DYN\_ROUTE\_SR\_LOW
- ARU\_[x]\_DYN\_ROUTE\_SR\_HIGH

For further information see the register part of this chapter.

# 28.5.4.1 Dynamic routing - CPU controlled

The dynamic routing feature can be enabled separately for ARU-0 and ARU-1 by setting the corresponding bit fields of the register **ARU\_CTRL**.

The enabling of the dynamic routing feature is synchronized to the normal routing scheme if ARU master ID-0 is addressed. The dynamic route will started with additional ARU master DYN\_READ\_ID0.

With the dynamic routing feature it is possible to insert additional ARU master ID's, DYN\_READ\_IDy (y:0-5), in a defined manner into the normal ARU routing scheme.

While inserting additional ARU master ID's the normal ARU routing scheme is paused. Therefore please consider that inserting additional ARU master ID's will lengthen the normal routing scheme.

It is possible to configure 6 additional ARU master ID's in the **ARU\_[x]\_DYN\_ROUTE\_LOW/\_HIGH** registers for both ARU-0 and ARU-1.

In the bit field **DYN\_CLK\_WAIT** of **ARU\_[x]\_DYN\_ROUTE\_HIGH** register the number of clock cycles has to be configured, after which one of the additional ARU master ID's will be inserted.

After each configured number of clock cycles the defined ARU master ID's will be inserted cyclic one after each other in the following manner:

... -> DYN\_READ\_ID0 -> DYN\_READ\_ID1 -> DYN\_READ\_ID2 -> DYN\_READ\_ID3 -> DYN\_READ\_ID4 -> DYN\_READ\_ID5 -> DYN\_READ\_ID0 -> ....

In the shadow registers **ARU\_[x]\_DYN\_ROUTE\_SR\_LOW/\_HIGH** further 6 ARU master, DYN\_READ\_IDy (y:6-11), can be configured.

The bit DYN\_UPDATE\_EN in the **ARU\_[x]\_DYN\_ROUTE\_SR\_HIGH** register controls whether the **ARU\_[x]\_DYN\_ROUTE\_LOW/\_HIGH** registers are updated from its shadow registers except DYN\_UPDATE\_EN, it is not updated. The update is executed once after writing **ARU\_[x]\_DYN\_ROUTE\_SR\_HIGH**. If update started DYN\_UPDATE\_EN is reset.

With the DYN\_ROUTE\_SWAP option in the **ARU\_[x]\_DYN\_CTRL** register it is possible to swap the registers **ARU\_[x]\_DYN\_ROUTE\_LOW/HIGH** with its shadow registers **ARU\_[x]\_DYN\_ROUTE\_SR\_LOW/HIGH**. The swapping is executed always after the 6 ARU master DYN\_READ\_ID's are inserted. So it is possible to insert a maximum of 12 ARU master DYN\_READ\_ID's cyclic after each configured number of clock cycles. If swap started DYN\_UPDATE\_EN is reset.

Setting the bit field **DYN\_CLK\_WAIT** of **ARU\_[x]\_DYN\_ROUTE\_HIGH** register to zero, only the defined ARU master DYN\_READ\_ID's will be executed. The normal ARU routing scheme is stopped.



#### **Generic Timer Module (GTM)**

Setting the bit field **DYN\_CLK\_WAIT** of **ARU\_[x]\_DYN\_ROUTE\_HIGH** register to 15, only the normal ARU routing scheme is executed. Inserting of additional ID's is stopped.

To reset the ARU caddr counter and ARU dynamic route counter set bit ARU\_ADDR\_RSTGLB of **CMU\_GLB\_CTRL** following by a write access to register **CMU\_CLK\_EN**.

## 28.5.4.1.1 Dynamic routing ring mode

In dynamic routing ring mode it is possible to use all 24 DYN\_READ\_ID's from both ARU-0 and ARU-1 by setting bit field ARU\_DYN\_RING\_MODE in **ARU\_CTRL** register to 1. In this mode all 4 registers **ARU\_[x]\_DYN\_ROUTE\_LOW/\_HIGH** and **ARU\_[x]\_DYN\_ROUTE\_SR\_LOW/\_HIGH** are connected as a ring, so all 24 DYN\_READ\_ID's can be used from both ARU's. The ring structure is shown in **Figure 24**. The data register shift direction is shown by the arrows in the ring.



Figure 24 ARU dynamic routing - ring mode

Enabling the dynamic routing ring mode will automatically reset the caddr counter of both ARU-0 and ARU-1. This is necessary to synchronize both ARU's in this mode.

Enabling the dynamic routing ring mode will ignored DYN\_ROUTE\_SWAP and DYN\_UPDATE\_EN.

Note: DYN ARU UPDATE EN should be disabled in dynamic routing ring mode.

It is possible to enable the dynamic routing ring mode for both ARU-0 and ARU-1 or only for one of the ARU's by setting the corresponding bit field ARU\_0\_DYN\_EN/ARU\_1\_DYN\_EN of the register **ARU\_CTRL**.

Because of the fact that to each ARU port ARU-0 and ARU-1 with the same ARU read ID two different GTM submodules are served it may make sense to enable ARU dynamic routing only for one port ARU-0 or ARU-1 if configured to ring-mode. The other port is then served in the default round robin manner.

In dynamic routing ring mode ARU\_[x]\_DYN\_ROUTE\_LOW/\_HIGH and ARU\_[x]\_DYN\_ROUTE\_SR\_LOW/\_HIGH are not write-protected. NOTE: Avoid modification of ARU\_[x]\_DYN\_ROUTE\_LOW/\_HIGH and ARU\_[x]\_DYN\_ROUTE\_SR\_LOW/\_HIGH in active dynamic routing ring mode.

## 28.5.4.2 Dynamic routing - ARU controlled

Furthermore it is possible to reload the **ARU\_[x]\_DYN\_ROUTE\_SR\_LOW/\_HIGH** registers by ARU itself.

Therefore the ARU has its own master port which will be served in the normal ARU routing scheme. The ARU read address for this master port has to be configured in the register **ARU [x] DYN RDADDR.**